<!--
  * 库存预警规则表
  *
  * @Author:    ADog
  * @Date:      2025-09-20 16:13:18
  * @Copyright  1.0
-->
<template>
  <a-modal
      :title="form.ruleId ? '编辑' : '添加'"
      :width="500"
      :open="visibleFlag"
      @cancel="onClose"
      :maskClosable="false"
      :destroyOnClose="true"
  >
    <a-form ref="formRef" :model="form" :rules="rules" :label-col="{ span: 5 }" >
        <a-form-item label="规则ID（主键）"  name="ruleId">
          <a-input-number style="width: 100%" v-model:value="form.ruleId" placeholder="规则ID（主键）" />
        </a-form-item>
        <a-form-item label="物料ID（关联t_core_material表，指定该规则适用的物料）"  name="materialId">
          <a-input-number style="width: 100%" v-model:value="form.materialId" placeholder="物料ID（关联t_core_material表，指定该规则适用的物料）" />
        </a-form-item>
        <a-form-item label="预警类型：1=低库存预警，2=临期预警，3=过期预警，4=高库存预警"  name="warnType">
          <a-input-number style="width: 100%" v-model:value="form.warnType" placeholder="预警类型：1=低库存预警，2=临期预警，3=过期预警，4=高库存预警" />
        </a-form-item>
        <a-form-item label="预警阈值（根据预警类型动态定义)"  name="warnThreshold">
          <a-input style="width: 100%" v-model:value="form.warnThreshold" placeholder="预警阈值（根据预警类型动态定义）：" />
        </a-form-item>
        <a-form-item label="规则是否启用：0=禁用（暂不生效），1=启用（参与预警判断）"  name="isEnabled">
          <a-input-number style="width: 100%" v-model:value="form.isEnabled" placeholder="规则是否启用：0=禁用（暂不生效），1=启用（参与预警判断）" />
        </a-form-item>
        <a-form-item label="规则创建时间"  name="createTime">
          <a-date-picker show-time valueFormat="YYYY-MM-DD HH:mm:ss" v-model:value="form.createTime" style="width: 100%" placeholder="规则创建时间" />
        </a-form-item>
        <a-form-item label="规则更新时间（修改时自动更新）"  name="updateTime">
          <a-date-picker show-time valueFormat="YYYY-MM-DD HH:mm:ss" v-model:value="form.updateTime" style="width: 100%" placeholder="规则更新时间（修改时自动更新）" />
        </a-form-item>
        <a-form-item label="规则备注（如“2024年Q4调整：高筋面粉低库存阈值从80kg改为100kg”）"  name="remark">
          <a-input style="width: 100%" v-model:value="form.remark" placeholder="规则备注（如“2024年Q4调整：高筋面粉低库存阈值从80kg改为100kg”）" />
        </a-form-item>
    </a-form>

    <template #footer>
      <a-space>
        <a-button @click="onClose">取消</a-button>
        <a-button type="primary" @click="onSubmit">保存</a-button>
      </a-space>
    </template>
  </a-modal>
</template>
<script setup>
  import { reactive, ref, nextTick } from 'vue';
  import _ from 'lodash';
  import { message } from 'ant-design-vue';
  import { SmartLoading } from '/src/components/framework/smart-loading';
  import { stockWarnRuleApi } from '/@/api/business/wms/stock/stock-warn-rule-api';
  import { smartSentry } from '/src/lib/smart-sentry';

  // ------------------------ 事件 ------------------------

  const emits = defineEmits(['reloadList']);

  // ------------------------ 显示与隐藏 ------------------------
  // 是否显示
  const visibleFlag = ref(false);

  function show(rowData) {
    Object.assign(form, formDefault);
    if (rowData && !_.isEmpty(rowData)) {
      Object.assign(form, rowData);
    }
    // 使用字典时把下面这注释修改成自己的字典字段 有多个字典字段就复制多份同理修改 不然打开表单时不显示字典初始值
    // if (form.status && form.status.length > 0) {
    //   form.status = form.status.map((e) => e.valueCode);
    // }
    visibleFlag.value = true;
    nextTick(() => {
      formRef.value.clearValidate();
    });
  }

  function onClose() {
    Object.assign(form, formDefault);
    visibleFlag.value = false;
  }

  // ------------------------ 表单 ------------------------

  // 组件ref
  const formRef = ref();

  const formDefault = {
      ruleId: undefined, //规则ID（主键）
      materialId: undefined, //物料ID（关联t_core_material表，指定该规则适用的物料）
      warnType: undefined, //预警类型：1=低库存预警，2=临期预警，3=过期预警，4=高库存预警
      warnThreshold: undefined, //预警阈值（根据预警类型动态定义）：
      isEnabled: undefined, //规则是否启用：0=禁用（暂不生效），1=启用（参与预警判断）
      createTime: undefined, //规则创建时间
      updateTime: undefined, //规则更新时间（修改时自动更新）
      remark: undefined, //规则备注（如“2024年Q4调整：高筋面粉低库存阈值从80kg改为100kg”）
  };

  let form = reactive({ ...formDefault });

  const rules = {
      ruleId: [{ required: true, message: '规则ID（主键） 必填' }],
      materialId: [{ required: true, message: '物料ID（关联t_core_material表，指定该规则适用的物料） 必填' }],
      warnType: [{ required: true, message: '预警类型：1=低库存预警，2=临期预警，3=过期预警，4=高库存预警 必填' }],
      warnThreshold: [{ required: true, message: '预警阈值（根据预警类型动态定义）：'}],
      isEnabled: [{ required: true, message: '规则是否启用：0=禁用（暂不生效），1=启用（参与预警判断） 必填' }],
      createTime: [{ required: true, message: '规则创建时间 必填' }],
      updateTime: [{ required: true, message: '规则更新时间（修改时自动更新） 必填' }],
      remark: [{ required: true, message: '规则备注（如“2024年Q4调整：高筋面粉低库存阈值从80kg改为100kg”） 必填' }],
  };

  // 点击确定，验证表单
  async function onSubmit() {
    try {
      await formRef.value.validateFields();
      save();
    } catch (err) {
      message.error('参数验证错误，请仔细填写表单数据!');
    }
  }

  // 新建、编辑API
  async function save() {
    SmartLoading.show();
    try {
      if (form.ruleId) {
        await stockWarnRuleApi.update(form);
      } else {
        await stockWarnRuleApi.add(form);
      }
      message.success('操作成功');
      emits('reloadList');
      onClose();
    } catch (err) {
      smartSentry.captureError(err);
    } finally {
      SmartLoading.hide();
    }
  }

  defineExpose({
    show,
  });
</script>
